package com.z.sys.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.z.sys.entity.Role;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * 角色管理Mapper接口
 *
 * @author z
 * @date 2022-11-07
 */
@Mapper
public interface RoleMapper extends BaseMapper<Role> {
    /**
     * 查询角色管理列表
     *
     * @param role 角色管理
     * @return 角色管理集合
     */
    List<Role> selectRoleList(Role role);

    /**
     * 根据userId查询权限集合
     * @param userId 职工id
     * @return list权限标识集合
     */
    @Select("SELECT permission FROM t_permission p LEFT JOIN t_role_permission rp on p.id=rp.permission_id LEFT JOIN t_dept_user_role ur on rp.role_id=ur.role_id where ur.user_id=#{userId}")
    List<String> selectPermissionByUserId(Long userId);

    /**
     * 根据userId查询角色集合
     * @param userId 职工id
     * @return list权限标识集合
     */
    @Select("SELECT DISTINCT r.name FROM t_role r LEFT JOIN t_dept_user_role ur on r.id=ur.role_id where ur.user_id=#{userId}")
    List<String> selectRoleNameByUserId(Long userId);
}
